package cn.test.my.excel.ss;

import java.io.File;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.alibaba.excel.write.metadata.fill.FillConfig;

/**
 * @author summit
 * @since 2021/7/15 14:48
 */
public class fuzha {

	public static void main(String[] args) {
		test();
	}

	public static void test() {

		// 模板注意 用{} 来表示你要用的变量 如果本来就有"{","}" 特殊字符 用"\{","\}"代替
		// {} 代表普通变量 {.} 代表是list的变量
//		String templateFileName =
//				TestFileUtil.getPath() + "demo" + File.separator + "fill" + File.separator + "complex.xlsx";
//
//		String fileName = TestFileUtil.getPath() + "complexFill" + System.currentTimeMillis() + ".xlsx";

		String templateFileName = "D:/test/fill-fuza.xlsx";
		// 结果输出路径
		String fileName = "D:/test/fuza2.xlsx";
		ExcelWriter excelWriter = EasyExcel.write(fileName).withTemplate(templateFileName).build();
		WriteSheet writeSheet = EasyExcel.writerSheet().build();
		// 这里注意 入参用了forceNewRow 代表在写入list的时候不管list下面有没有空行 都会创建一行，然后下面的数据往后移动。默认 是false，会直接使用下一行，如果没有则创建。
		// forceNewRow 如果设置了true,有个缺点 就是他会把所有的数据都放到内存了，所以慎用
		// 简单的说 如果你的模板有list,且list不是最后一行，下面还有数据需要填充 就必须设置 forceNewRow=true 但是这个就会把所有数据放到内存 会很耗内存
		// 如果数据量大 list不是最后一行 参照下一个
		FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
		excelWriter.fill(data(), fillConfig, writeSheet);
		excelWriter.fill(data(), fillConfig, writeSheet);
		Map<String, Object> map = new HashMap<String, Object>();
		map.put("date", "2019年10月9日13:28:28");
		map.put("total", 1000);
		excelWriter.fill(map, writeSheet);
		excelWriter.finish();
	}

	private static List<FillData> data() {
		List<FillData> list = new ArrayList<FillData>();
		for (int i = 0; i < 10; i++) {
			FillData fillData = new FillData();
			list.add(fillData);
			fillData.setName("张三");
			fillData.setNumber(5);
		}
		return list;
	}
}
